﻿#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
// 原题连接：https://leetcode.cn/problems/height-checker/
/*
题目描述：
学校打算为全体学生拍一张年度纪念照。根据要求，学生需要按照 非递减 的高度顺序排成一行。
排序后的高度情况用整数数组 expected 表示，其中 expected[i] 是预计排在这一行中第 i 位的学生的高度（下标从 0 开始）。
给你一个整数数组 heights ，表示 当前学生站位 的高度情况。heights[i] 是这一行中第 i 位学生的高度（下标从 0 开始）。
返回满足 heights[i] != expected[i] 的 下标数量 。

 

示例：
输入：heights = [1,1,4,2,1,3]
输出：3
解释：
高度：[1,1,4,2,1,3]
预期：[1,1,1,2,3,4]
下标 2 、4 、5 处的学生高度不匹配。

示例 2：
输入：heights = [5,1,2,3,4]
输出：5
解释：
高度：[5,1,2,3,4]
预期：[1,2,3,4,5]
所有下标的对应学生高度都不匹配

示例 3：
输入：heights = [1,2,3,4,5]
输出：0
解释：
高度：[1,2,3,4,5]
预期：[1,2,3,4,5]
所有下标的对应学生高度都匹配。
 

提示：
1 <= heights.length <= 100
1 <= heights[i] <= 100
*/


// 开始解题：
// 方法1——排序
int cmp_int(const void* p1, const void* p2) {
    assert(p1 && p2);
    return *(int*)p1 - *(int*)p2;
}
int heightChecker(int* heights, int heightsSize) {
    assert(heights);
    int i = 0;
    int answer = 0;
    int* expected = (int*)malloc(heightsSize * sizeof(int));
    if (NULL == expected) {
        perror("malloc fail!\n");
        exit(-1);
    }
    for (i = 0; i < heightsSize; i++) {
        expected[i] = heights[i];
    }
    qsort(expected, heightsSize, sizeof(int), cmp_int);
    for (i = 0; i < heightsSize; i++) {
        if (expected[i] != heights[i]) {
            answer++;
        }
    }
    free(expected);
    expected = NULL;
    return answer;
}